草庐IT

c++ - std::transform 的泛化

全部标签

c++ - 如何中断其他 std::threads C++

我有一个服务器,它是以每个客户端一个线程的方式构建的。最近,我遇到了一个很难想出解决方案的问题,所以我想寻求帮助。我的服务器有一个大厅,大厅里有很多房间(都是用户的),房间里有玩家。每个房间都有一个管理员,当管理员选择离开时-房间关闭,所有用户都应该返回大厅。现在,我已经有了一个工作代码-但问题是,我不知道我应该如何让其他客户也退出房间。线程中运行的代码如下:while(in_lobby){//Receiveamessage//Dostuff//IncertaincaseschangetheBooleantofittothesituation//Sendacomeback}while(

具有复杂结构的 C++ 初始化列表

我正在修改此C代码以与G++编译器一起使用,但我被困在这个相当复杂的结构上。G++编译器提示“抱歉,未实现:不支持非平凡的指定初始值设定项”。我知道一个涉及编写构造函数的解决方案,但对构造函数的调用将是巨大的并且太困惑了。是否有某种方法可以简化它并折射它,以便它更具可读性和g++兼容。staticconststruct{struct{__le32magic;__le32length;#ifndefUSE_DEPRECATED_DESC_HEAD__le32flags;#endif__le32fs_count;__le32hs_count;}__attribute__((packed))

c++ - 实现 Halstead 复杂性指标的问题

我目前正在练习一个简单的程序,以理解从Halstead的软件科学中推导出各种指标所涉及的方程式。我确实相信我做的是正确的,但我觉得我还没有注册所有的操作数和运算符,这样我就可以从数学开始了。我正在使用的程序是:/*01*///countshowmanyitemsinsArray[]arealsointArray[]/*02*/intmatched(intsArray[],inttArray[],intsMax,inttMax)/*03*/{/*04*/intcount,i,first,middle,last;/*05*//*06*/for(i=0;i我已经出来了n1=不同运算符的数量=

c++ - 为什么不能将 mem_fn 应用于 std::string 的成员函数?

structint_holder{intvalue;inttriple(){returnvalue*3;}};intmain(intargc,constchar*argv[]){std::stringabc{"abc"};int_holderone{1};autof1=mem_fn(&std::string::clear);autof2=mem_fn(&int_holder::triple);f1(abc);f2(one);}我在Xcode中测试这样的代码,编译器发出这样的错误似乎mem_fn可以用于用户定义类的成员函数,但不能用于标准字符串的成员函数,有什么不同,为什么?感谢您的阅读

c++ - 我可以在函数头中包含 cppcheck 抑制吗?

我添加了一个内联注释来抑制函数的cppcheckunusedFunction警告,但我想将其包含在函数头中,以便Doxygen可以记录所有未使用的函数(我正在实现一个API,所以我有许多函数不会在我的源代码中使用)。我不希望抑制所有unusedFunction错误,而是基于每个函数。我想做这样的事情:/***APIfunctiondescription**@paramp1functionpointertothe...*@return0ifsuccessful,-1otherwise.*//cppcheck-suppressunusedFunction*/intCreateTask(Ta

c++ - recvfrom() 是否在出错时修改 src_addr?

我目前正在编写一个供个人使用的小型UDP套接字库,但我一直无法找到这方面的任何文档。我指的函数是ssize_trecvfrom(intsockfd,void*buf,size_tlen,intflags,structsockaddr*src_addr,socklen_t*addrlen);,来自POSIX标题。我想重复使用src_addr结构我传递给recvfrom与sendto一起使用(相同的标题)无论是否recvfrom成功或失败。成功后,它将包含向其发送数据的对等方的地址(在我的用例中只有一个),这是预期的行为;但是,它会生成错误EAGAIN当非阻塞读取失败时,src_addr的

C++11:std::mem_fn 的类型名称

auto很好,但我需要在类中声明一个成员,而不是堆栈中的变量。decltype有效,但不知何故看起来很奇怪classAutomation{void_init_state(int);decltype(std::mem_fn(&Automation::_init_state))next_state;};std::function似乎也可以,但与纯成员函数有细微差别classAutomation{void_init_state(int){}public:decltype(std::mem_fn(&Automation::_init_state))next_state;std::functio

c++ - 是否可以从宏定义宏

这是我的想法。#defineprefix_11#defineprefix_22#defineprefix_33我想使用上面的前缀定义一个宏——比如宏macro_prefix_1macro_prefix_2——我希望它们变成macro_1macro_2等,就像下面的代码#definemacro_##prefix_1I_am_macro_1#definemacro_##prefix_2I_am_macro_2这可能吗? 最佳答案 不幸的是,你想做的事是不可能的。(##)指令不可能在宏声明中使用。只能在定义中使用它。#defineglue

c++ - CMake 包含和源路径与 Windows 目录路径不同

我想用VisualStudio2010/VC10和CMake创建一个库。Windows的树与CMake的项目树不同。问题是CMake不会在VisualStudio中创建带有头文件和源文件的foolib。我无法更改库的树,因为它是一个古老的代码,有很多共享多个包含文件的库。root|-'includes|'-foo.h|-'src|'-libprojects||'-foolib|||'-bin|||'-project||||'-mak100||||'-CMakeLists01.txt|||'-src||||'-CMakeLists02.txt||||'-foo.cxxCMakeLists

c++ - Clang 不能与 std::experimental::optional 一起正常工作

clang似乎不能与std::experimental::optional一起正常工作。考虑以下示例:#include#includestructFoo{intbar;};intmain(){Foofoo;std::experimental::optionalopt=foo;opt.value().bar=42;std::cout它在g++5.3.1版中编译良好,但在clang7.0.0版和clang7.0.2版中均无法编译。返回的错误是:Undefinedsymbolsforarchitecturex86_64:"std::experimental::bad_optional_acc